<template>
  <!--  template中书写组建的结构-->
  <div class="manage">
    <el-dialog
        :title="operateType==='add'? '新增用户' : '更新用户'"
        :visible.sync="isShow"
    >
      <common-form
          :formLabel="operateFormLabel"
          :form="operateForm"
          :inline="true"
          ref="form"
      ></common-form>
      <div slot="footer" class="dialog-footer">
        <el-button @click="isShow = false">取消</el-button>
        <el-button type="primary" @click="confirm">确定</el-button>
      </div>
    </el-dialog>
    <div class="manage-header">
      <el-button type="primary" @click="addUser">+ 新增</el-button>
      <common-form
          :formLabel="formLabel"
          :form="searchForm"
          :inline="true"
          ref="form"
      >
        <el-button type="primary" @click="getList(searchForm.keyword)">搜索</el-button>
      </common-form>
    </div>
    <common-table
        :table-data="tableData"
        :table-label="tableLabel"
        :config="config"
        @changePage="getList()"
        @edit="editUser"
        @del="delUser"
    ></common-table>
  </div>
</template>

<script>
// script中书写组件交互相关的代码(数据、方法等)
import CommonForm from "@/components/CommonForm";
import CommonTable from "@/components/CommonTable";
import {getUser} from '../../api/data'

export default {
  name: "User",
  // 注册子组件
  components: {CommonForm, CommonTable},
  data() {
    return {
      operateType: 'add',
      isShow: false,
      operateFormLabel: [
        {
          model: 'name',
          label: '姓名',
          type: 'input'
        },
        {
          model: 'age',
          label: '年龄',
          type: 'input'
        },
        {
          model: 'sex',
          label: '性别',
          type: 'select',
          opts: [
            {
              label: '男',
              value: 1
            },
            {
              label: '女',
              value: 0
            }
          ]
        },
        {
          model: 'birth',
          label: '出生日期',
          type: 'date'
        },
        {
          model: 'addr',
          label: '地址',
          type: 'input'
        }
      ],
      operateForm: {
        name: '',
        addr: '',
        age: '',
        birth: '',
        sex: ''
      },
      formLabel: [
        {
          model: "keyword",
          label: '',
          type: 'input'
        }
      ],
      searchForm: {
        keyword: ''
      },
      tableData: [],
      tableLabel: [
        {
          prop: "name",
          lable: "姓名",
        },
        {
          prop: "age",
          lable: "年龄",
        },
        {
          prop: "sexLable",
          lable: "性别",
        },
        {
          prop: "birth",
          lable: "出生日期",
          width: 200
        },
        {
          prop: "addr",
          lable: "地址",
          width: 320
        }
      ],
      config: {
        page: 1,
        total: 30,

      }
    }
  },
  methods: {
    confirm() {
      if (this.operateType === 'edit') {
        this.axios.post('/user/edit', this.operateForm).then(res => {
          console.log(res)
          this.isShow = false
          this.getList()
        })
      } else {
        this.$http.post('/user/add', this.operateForm).then(res => {
          this.isShow = false
          this.getList()
        })
      }
    },
    addUser() {
      this.isShow = true
      this.operateType = 'add'
      this.operateForm = {
        name: '',
        addr: '',
        age: '',
        birth: '',
        sex: ''
      }
    },
    getList(name = '') {
      this.config.loadding = true
      name ? (this.config.page = 1) : ''
      getUser({
        page: this.config.page,
        name: name
      }).then(({data: res}) => {
        this.tableData = res.list.map(item => {
          item.sexLable = item.sex === 0 ? '女' : '男'
          return item
        })
        this.config.total = res.count
        this.config.loading = false
      })
    },
    editUser(row) {
      this.operateType = 'edit',
          this.isShow = true,
          this.operateForm = row
    },
    delUser(row) {
      this.$confirm("此操作将永久删除该组件，是否继续？", "提示", {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: "warning"
      }).then(() => {
        const id = row.id
        this.$http.post("/user/del", {
          params: {id}
        }).then(res => {
          this.$message({
            type: 'success',
            message: "删除成功"
          })
          this.getList()
        })
      })
    }
  },
  created() {
    this.getList()
  }
}
</script>

<style lang="less" scoped>
/*style书写组建的样式*/
.manage-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
</style>